/* -------------------------------------------------------------- */
/* Normalize Reset 
-------------------------------------------------------------- */

* {
  box-sizing: border-box;
}

html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}
/* Sections
       ========================================================================== */
/**
     * Remove the margin in all browsers.
     */
body {
  margin: 0;
}
/**
     * Render the `main` element consistently in IE.
     */
main {
  display: block;
}
/**
     * Correct the font size and margin on `h1` elements within `section` and
     * `article` contexts in Chrome, Firefox, and Safari.
     */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
/* Grouping content
       ========================================================================== */
/**
     * 1. Add the correct box sizing in Firefox.
     * 2. Show the overflow in Edge and IE.
     */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}
/**
     * 1. Correct the inheritance and scaling of font size in all browsers.
     * 2. Correct the odd `em` font sizing in all browsers.
     */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}
/* Text-level semantics
       ========================================================================== */
/**
     * Remove the gray background on active links in IE 10.
     */
a {
  background-color: transparent;
}
/**
     * 1. Remove the bottom border in Chrome 57-
     * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
     */
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}
/**
     * Add the correct font weight in Chrome, Edge, and Safari.
     */
b,
strong {
  font-weight: bolder;
}
/**
     * 1. Correct the inheritance and scaling of font size in all browsers.
     * 2. Correct the odd `em` font sizing in all browsers.
     */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}
/**
     * Add the correct font size in all browsers.
     */
small {
  font-size: 80%;
}
/**
     * Prevent `sub` and `sup` elements from affecting the line height in
     * all browsers.
     */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
/* Embedded content
    ========================================================================== */
/**
     * Remove the border on images inside links in IE 10.
     */
img {
  border-style: none;
}
/* Forms
       ========================================================================== */
/**
     * 1. Change the font styles in all browsers.
     * 2. Remove the margin in Firefox and Safari.
     */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}
/**
     * Show the overflow in IE.
     * 1. Show the overflow in Edge.
     */
button,
input {
  /* 1 */
  overflow: visible;
}
/**
     * Remove the inheritance of text transform in Edge, Firefox, and IE.
     * 1. Remove the inheritance of text transform in Firefox.
     */
button,
select {
  /* 1 */
  text-transform: none;
}
/**
     * Correct the inability to style clickable types in iOS and Safari.
     */
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}
/**
     * Remove the inner border and padding in Firefox.
     */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}
/**
     * Restore the focus styles unset by the previous rule.
     */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}
/**
     * Correct the padding in Firefox.
     */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}
/**
     * 1. Correct the text wrapping in Edge and IE.
     * 2. Correct the color inheritance from `fieldset` elements in IE.
     * 3. Remove the padding so developers are not caught out when they zero out
     *    `fieldset` elements in all browsers.
     */
legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}
/**
     * Add the correct vertical alignment in Chrome, Firefox, and Opera.
     */
progress {
  vertical-align: baseline;
}
/**
     * Remove the default vertical scrollbar in IE 10+.
     */
textarea {
  overflow: auto;
}
/**
     * 1. Add the correct box sizing in IE 10.
     * 2. Remove the padding in IE 10.
     */
[type="checkbox"],
[type="radio"] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}
/**
     * Correct the cursor style of increment and decrement buttons in Chrome.
     */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
/**
     * 1. Correct the odd appearance in Chrome and Safari.
     * 2. Correct the outline style in Safari.
     */
[type="search"] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}
/**
     * Remove the inner padding in Chrome and Safari on macOS.
     */
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
/**
     * 1. Correct the inability to style clickable types in iOS and Safari.
     * 2. Change font properties to `inherit` in Safari.
    */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}
/* Interactive
       ========================================================================== */
/*
     * Add the correct display in Edge, IE 10+, and Firefox.
     */
details {
  display: block;
}
/*
     * Add the correct display in all browsers.
     */
summary {
  display: list-item;
}
/* Misc
       ========================================================================== */
/**
     * Add the correct display in IE 10+.
     */
template {
  display: none;
}
/**
     * Add the correct display in IE 10.
     */
[hidden] {
  display: none;
}

/* END OF NORMALIZE-------------------------------------------------------------- */

body {
  font-family: "Work Sans", serif;
}

/* Hero Section */

.main-header,
.pp-main {
  background: #f6f2e7;
}
.main-header {position: relative;z-index: 4;;}
.logo-container {
  display: flex;
  justify-content: center;
  position: sticky;
  top:0;
  z-index: 5;
  background-color: #f6f2e7;
}

.logo-container a {
  transition: 0.4s;
  margin: 50px 0px;
}

.logo-container img {
  height: 80px;
  width: auto;
}

.hero-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  overflow: hidden;
  margin-bottom: 48pt;
}

.text-line-container {
  position: relative;
  margin: 20px 0;
}

.hero-text h1 {
  position: relative;
  background: #f6f2e7;
  padding-left: 10px;
  width: 100vw;
  margin: 20px 0px;
  font-family: "DM Serif Display", serif;
  font-style: italic;
  font-weight: 400;
  color: #333;
  font-size: 70px;
  display: inline-block;
  white-space: nowrap;
}

.line-blue,
.line-red,
.line-yellow {
  position: absolute;
  height: 6px;
  width: 0;
  border-radius: 10px;
}

.line-blue {
  background: #2151f3;

  top: 50%;
  animation: grow-line-blue 1.5s ease forwards;
}

.line-red {
  background: #f65900;

  top: 50%;
  animation: grow-line-red 2s ease forwards;
}

.line-yellow {
  background: #ffda35;

  top: 50%;
  animation: grow-line-yellow 2.5s ease forwards;
}

.blue-h1 {
  animation: move-text-blue 1.5s ease forwards;
}

.red-h1 {
  animation: move-text-red 2s ease forwards;
}

.yellow-h1 {
  animation: move-text-yellow 2.5s ease forwards;
}

@keyframes move-text-blue {
  from {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(10vw);
    transform: translateX(10vw);
  }
}
@keyframes move-text-red {
  from {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  to {
    transform: translateX(35vw);
    transform: translateX(35vw);
  }
}
@keyframes move-text-yellow {
  from {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(65vw);
    transform: translateX(65vw);
  }
}

@keyframes grow-line-blue {
  from {
    width: 0%;
  }
  to {
    width: calc(49vw + 100%);
  }
}

@keyframes grow-line-red {
  from {
    width: 0%;
  }
  to {
    width: calc(64vw + 100%);
  }
}

@keyframes grow-line-yellow {
  from {
    width: 0%;
  }
  to {
    width: calc(71vw + 100%);
  }
}

.department-parent-container {
  background: #eee5d0;
}

.department-container {
  width: 90%;
  display: flex;
  justify-content: space-around;
  margin: 0 auto;
  padding: 100px 0;
  flex-wrap: wrap;
}

.department-container h3 {
  color: #1e235a;
  font-weight: 400;
  /* font-size: 18px; */
  font-size: 1.2rem;
  padding: 0 10px;
}

.hero-subtext h2 {
  color: #24252a;
  font-size: 40px;
  width: 60%;
  margin: auto;
  font-weight: 300;
  line-height: 130%;
  padding: 100px 0;
}

.believe-text {
  font-family: "DM Serif Display", serif;
  color: #2151f3;
  font-style: italic;
}
.client-logo-container {
  display: flex;
  justify-content: space-around;
  align-items: center;
  flex-wrap: wrap;
  gap: 20px;
  padding: 100px 0;
  width: 90%;
  margin: 0 auto;
}

.single-logo img {
  height: 60px;
  width: auto;
}

/* Second section */

.second-section {
  background: #eee5d0;
  padding: 50px 0 100px 0;
  border-bottom: 20px solid #ff4c00;

  position: relative;
  z-index: 1;
}

.second-section .inner {
  width: 90%;
  margin: auto;
  max-width: 1200px;
}

.second-section h1 {
  font-size: 45px;
  color: #2151f3;
  font-weight: 700;
}

.values-container {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  padding-top: 30px;
}

.value-box {
  background-color: #f6f2e7;
  flex: 1 1 calc(50% - 10px);
  min-height: 290px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
  border-radius: 10px;
  overflow: hidden;
}

.value-icon-container {
  margin-bottom: 15px;
}

.value-icon-container img {
  width: auto;
  height: 35px;
  object-fit: contain;
}

.value-box h4 {
  margin: 0 0 10px 0;
  font-size: 38px;
  width: 70%;
  font-weight: 600;
  color: #1e235a;
  z-index: 4;
}

.value-box p {
  margin: 0;
  width: 70%;
  font-size: 20px;
  font-weight: 400;
  color: #1e235a;
  flex-grow: 1;
  z-index: 4;
}

.value-number {
  position: absolute;
  bottom: -4px;
  right: 3px;
}

.value-number.value-one {
  right: 32px;
}

.value-number img {
  width: auto;
  height: 250px;
  object-fit: contain;
}

/*Contact Section*/

.contact-information {
  background: #f6f2e7;
  padding: 50px 0px;
}

.contact-information .inner {
  padding: 50px 0px;
  width: 90%;
  margin: 0 auto;
  max-width: 1200px;
}

.contact-information h1 {
  color: #1e235a;
  font-size: 45px;
  font-weight: 700;
}

.contact-container {
  display: flex;
  gap: 20px;
}

.contact-container > div:not(.map-container) {
  flex: 1;
}

.map-container {
  flex: 1;
}

.telephone,
.email {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
}

.telephone img,
.email img {
  width: 24px;
  height: 24px;
}

.telephone a,
.email a {
  text-decoration: none;
  color: #24252a;
  font-size: 18px;
  word-break: break-word;
  transition: 0.25s ease-in-out;
}

.telephone a:hover,
.email a:hover {
  color: #f65900;
}

.contact-form {
  margin-top: 30px;
}

.contact-form form {
  display: flex;
  flex-direction: column;
  gap: 15px;
  padding-right: 60px;
}

.contact-form input,
.contact-form textarea {
  padding: 12px;
  background-color: #faf8f4;
  color: #24252a;
  padding: 12px;
  border-bottom: 1px solid #666;
  border-top: none;
  border-right: none;
  border-left: none;
}

textarea {
  resize: none;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
  color: #24252a;
}

.contact-form input[type="submit"] {
  background: #2151f3;
  color: white;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  width: 30%;
  border: none;
  border-radius: 70px;
  padding: 20px;
  text-align: center;
  margin-top: 80px;
  background-image: url(/images/submit_hover.png);
  background-position: 50% 100px;
  background-size: cover;
  background-repeat: no-repeat;
  transition: 0.25s ease-in-out;
}

.contact-form input[type="submit"]:hover {
  background-position: center;
  background-size: 165%;
  cursor: pointer;
}

#thankYouMessage,
#errorMessage {
  opacity: 1 !important;
  font-size: 35px;
}

.map-container p {
  margin-bottom: 20px;
  padding-left: 10px;
  font-size: 18px;
}

.map-text {
  display: flex;
  align-items: center;
  font-size: 20px;
  font-weight: 400;
  color: #24252a;
}

a.map-link {
  text-decoration: none;
  cursor: pointer;
  color: #24252a;
  display: flex;
  transition: 0.25s ease-in-out;
}

a.map-link:hover {
  color: #f65900;
}

.map-img-container {
  border-radius: 5px;
  border: 4px solid #e8dec4;
  height: 500px;
}

.map-img-container iframe {
  width: 100%;
  height: 100%;
}

/* Footer Section */

.top-footer {
  background: #2151f3;
  padding: 50px 0;
}

.top-footer .inner {
  width: 90%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.footer-logo img {
  height: 200px;
  width: auto;
}

.footer-address {
  text-align: center;
}

.footer-address p,
.footer-address a {
  color: #ccc;
  font-size: 18px;
  margin: 10px 0;
  transition: 0.25s ease-in-out;
}

.footer-address a:hover {
  color: #ffda34;
}

.phone a {
  text-decoration: none;
}

.bottom-footer {
  background: #1e235a;
  position: relative;
  z-index: 10000;
}

.bottom-footer .inner {
  padding: 10px 0px;
  display: flex;
  gap:10px;
  justify-content: space-between;
  align-items: center;
  width: 80%;
  margin: 0 auto;
}

.bottom-footer .inner p,
.bottom-footer .inner a {
  color: #e8dec4;
  font-size: 18px;
  font-weight: 400;
  transition: 0.25s ease-in-out;
}

a.p-link:hover {
  color: #ffda35;
}

.social-media {
  display: flex;
  gap: 30px;
}

.social-media a img {
  height: 30px;
  width: auto;
  transition: 0.25s ease-in-out;
}

.social-media a img:hover {
  filter: invert(1) brightness(6) saturate(20) hue-rotate(235deg);
}

/*Privacy Policy*/

.pp-main {
  padding: 50px 0;
}
.pp-div {
  width: 90%;
  margin: 0 auto;
  font-size: 20px;
}

h1.pp-h-tag {
  color: #24252a;
  font-weight: 700;
  font-size: 40px;
}

.text-line-container {
  overflow: hidden;
}

#thankYouMessage {
  margin-top: 20px;
  scroll-padding-top: 20px;
}
#errorMessage {
  margin-top: 20px;
  scroll-padding-top: 20px;
}

h2.pp-h-tag {
  color: #24252a;
  font-weight: 600;
  font-size: 30px;
}

.pp-link {
  color: #2151f3;
  text-decoration: none;
}

.pp-link:hover {
  color: #f65900;
}



/* -------------------------------------------------------------- */
/* Animate CSS
  -------------------------------------------------------------- */
.fade-in-from-left {
  opacity: 0;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  -webkit-transform: translateX(-15px);
  -ms-transform: translateX(-15px);
  transform: translateX(-15px);
}

.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.fade-in-from-left.animated {
  -webkit-animation-name: fade-from-left;
  animation-name: fade-from-left;
  -webkit-animation-duration: 0.5s;
  animation-duration: 0.5s;
  opacity: 1;
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0);
}

@-webkit-keyframes fade-from-left {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-15px);
    -ms-transform: translateX(-15px);
    transform: translateX(-15px);
  }

  45% {
    opacity: 0.5;
  }

  90% {
    opacity: 1;
  }

  100% {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}

@keyframes fade-from-left {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-15px);
    -ms-transform: translateX(-15px);
    transform: translateX(-15px);
  }

  45% {
    opacity: 0.5;
  }

  90% {
    opacity: 1;
  }

  100% {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}

.fade-in-from-bottom {
  opacity: 0;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  -webkit-transform: translateY(15px);
  -ms-transform: translateY(15px);
  transform: translateY(15px);
}

.fade-in-from-bottom.animated {
  -webkit-animation-name: fade-from-bottom;
  animation-name: fade-from-bottom;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  opacity: 1;
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0);
}

@-webkit-keyframes fade-from-bottom {
  0% {
    opacity: 0;
    -webkit-transform: translateY(15px);
    -ms-transform: translateY(15px);
    transform: translateY(15px);
  }
  90% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}

@keyframes fade-from-bottom {
  0% {
    opacity: 0;
    -webkit-transform: translateY(15px);
    -ms-transform: translateY(15px);
    transform: translateY(15px);
  }
  90% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}

.fade-in-from-right {
  opacity: 0;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  -webkit-transform: translateX(40px);
  -ms-transform: translateX(40px);
  transform: translateX(40px);
}

.fade-in-from-right.animated {
  -webkit-animation-name: fade-from-right;
  animation-name: fade-from-right;
  -webkit-animation-duration: 0.5s;
  animation-duration: 0.5s;
  opacity: 1;
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0);
}

@-webkit-keyframes fade-from-right {
  0% {
    opacity: 0;
    -webkit-transform: translateX(40px);
    -ms-transform: translateX(40px);
    transform: translateX(40px);
  }

  90% {
    opacity: 1;
  }

  100% {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}

@keyframes fade-from-right {
  0% {
    opacity: 0;
    -webkit-transform: translateX(40px);
    -ms-transform: translateX(40px);
    transform: translateX(40px);
  }

  90% {
    opacity: 1;
  }

  100% {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}

@-webkit-keyframes gradient {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

@keyframes gradient {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}
